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25 

Sir: 



Appellant hereby replies to the Examiner's Answer, mailed May 12, 2011 
(referred to hereinafter as "the Examiner's Answer"), in an Appeal of the final rejection of 
30 claims 1-8 and 18-24 in the above-identified patent application. 



REAL PARTY IN INTEREST 
A statement identifymg the real party m interest is contained m Appellant's 



Appeal Brief. 



35 



RELATED APPEALS AND INTERFERENCES 



A statement identifying related appeals is contained in Appellant's Appeal Brief. 



40 



Brief. 



STATUS OF CLAIMS 
A statement identifying the status of the claims is contained in Appellant's Appeal 
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STATUS OF AMENDMENTS 
A statement identifying the status of the amendments is contained in Appellant's 

Appeal Brief. 

5 SUMMARY OF CLAIMED SUBJECT MATTER 

A Summary of the Invention is contained in Appellant's Appeal Brief. 

STATEMENT OF GROUNDS OF REJECTION TO BE REVIEWED ON APPEAL 

A statement identifying the grounds of rejection to be reviewed on appeal is 
10 contained in Appellant's Appeal Brief. 

CLAIMS APPEALED 
A copy of the appealed claims is contained in an Appendix of Appellant's Appeal 

Brief. 

15 

ARGUMENT 

Independent Claims I and 18 

Independent claims 1 and 18 were rejected under 35 U.S.C. § 103(a) as being 
unpatentable over MuUer et al. in view of Sindhu et al. Regarding claim 1, the Examiner asserts 

20 that Sindhu discloses storing in said shared memory (FIG. 9, shared memory), wherein said 
shared memory comprises two or more buffers (FIG. 9: M (0), M (1), M (2), M (3), M (4), M 
(5), M (6), M (7)), at least a portion of a packet in contiguous banks (FIG. 9, banks 902) of a first 
buffer (M (0)) of said two or more buffers, wherein each of said banks (FIG. 9, banks 902) 
comprises portions, wherein each of said two or more buffers comprises a portion from each of 

25 said plurality of banks, and wherein each of said buffers identifies an address of a location in 
each of said banks (col. 14, lines 30-35). In the Advisory Action dated December 14, 2009, the 
Examiner asserts that MuUer discloses where each of said two or more buffers comprises a 
portion firom each of said plurality of banks (col. 8, lines 43-45; the buffers may be further 
subdivided into a number of memory lines). 

30 Appellants note that Sindhu teaches that FIG. 9 illustrates a reservation table 508 

that "includes a plurality of columns 900, one for each memory bank 105 in global data buffer 
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104, a plurality of rows 902" (col. 11, lines 22-26; emphasis added) and that '"each row 
represents a set of read requests" (col. 11, lines 26-27; emphasis added). Thus, contrary to the 
Examiner's assertion, FIG. 9 does not represent a shared memory (as defined in the context of 
the present invention and as is well known in the art); the columns of table 508 are not buffers; 
5 and the rows of table 508 are not banks. Furthermore, Sindhu's teaching at col. 14, lines 30-35, 
refers to memory banks 105 of FIG. 2B (see, cols. 12-14); Sindhu's teaching at col. 14, lines 30- 
35, does not refer to the rows 902 of table 508. 

Furthermore, as the Examiner previously acknowledged, MuUer teaches that the 
buffers may be further subdivided into a number of memory lines; MuUer does not disclose or 
10 suggest where each of the buffers comprise a portion from each of said plurality of banks . 

In the Response to Arguments section of the present Office Action, the Examiner 
equates the claimed two or more buffers with buffers #1-3 (FIG. 3 A) of MuUer. The Examiner 
also equates the claimed banks with buffers #1-3 (FIG. 3 A) of MuUer and equates the claimed 
first buffer with the shared memory 230 of FIG. 3A. Appellants find no logic in the apparent 
15 inconsistency of equating the claimed buffers and banks with the same entities in MuUer, It is 
noted that the cited claims require wherein each of said banks comprises portions, and wherein 
each of said two or more buffers comprises a portion from each of said plurality of banks. 

Furthermore, neither MuUer nor Sindhu, alone or in combination, disclose or 
suggest that a shared memory comprises two or more buffers and two or more banks, wherein 
20 each of the banks comprises portions, wherein each of the two or more buffers comprises a 
portion from each of the plurality of banks, and wherein each of the buffers identifies an 
address of a location in each of the banks . 

Thus, MuUer et al. and Sindhu et al., alone or in combination, do not disclose or 
suggest wherein said shared memory comprises two or more buffers and two or more banks, at 
25 least a portion of a packet in contiguous banks of a first buffer of said two or more buffers, 
wherein each of said banks comprises portions, wherein each of said two or more buffers 
comprises a portion from each of said plurality of banks, and wherein each of said buffers 
identifies an address of a location in each of said banks, as required by independent claims 1 and 
18. 

30 
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Claims 2 and 19 

Claims 2 and 19 are rejected imder 35 U.S.C. § 103(a) as being unpatentable over 
Muller et al. in view of Sindhu et al, and further in view of Benson et al. In particular, the 
Examiner acknowledges that Muller and Sindhu do not explicitly teach said data unit stored in 
5 said last bank of said first buffer is not a last data unit of said packet, but asserts that Benson 
teaches storing an additional portion (the rest of the cell of the packet) of said packet in a second 
buffer (the second card buffer) if one of said portions (the cell of the packet) is stored in said first 
buffer (the first card buffer) and said portions stored in said first buffer (the first card buffer) is 
not a last portion of said packet (FIG. IB, place enough data in the first card buffer to fill the host 
10 buffer, place the rest of the cell into the second card buffer). 

As the Examiner notes, FIG. 7B of Benson teaches placing enough data in the 
first card buffer to fill the host buffer, and placing the rest of the cell into the second card buffer. 
Benson, however, does not disclose or suggest storing an additional portion of a packet in 
contieuous banks of a second buffer if one of the portions is stored in a last bank of a first buffer 
15 and a portion stored in the last bank of the first buffer is not a last portion of the packet. 

Thus, Muller et al., Sindhu et al., and Benson et al., alone or in combination, do 
not disclose or suggest wherein said packet comprises a plurality of portions, and further 
comprising the step of storing an additional portion of said packet in contiguous banks of a 
second buffer if one of said portions is stored in a last bank of said first buffer and said portion 
20 stored in said last bank of said first buffer is not a last portion of said packet, as required by 
claims 2 and 19. 

Claims 6 and 22 

Claims 6 and 22 are rejected under 35 U.S.C. § 103(a) as being unpatentable over 
Muller et al. and Sindhu et al., in view of Lavelle et al. In particular, the Examiner 
25 acknowledges that Muller and Sindhu do not explicitly teach, but asserts that Lavelle teaches 
wherein said banks are divided into a first set of banks and a second set of banks, and a buffer 
that comprises one or more banks from said first set and a buffer that comprises one or more 
banks from said second set (col. 14, lines 59-62; a frame buffer, wherein the frame buffer 
includes a first set of one or more banks, a second set of one or more memory banks). 

30 
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Appellant notes that, in the text cited by the Examiner, Lavelle teaches: 

a frame buffer, wherein the frame buffer includes a first set of one or more 
memory banks, a second set of one or more memory banks, and a cache, wherein 
the frame buffer is configured to load data from the first set into the cache in 
5 response to receiving a cache fill request targeting the first set, wherein the first 

set is accessible independently of the second set 
(Col, 14, lines 59-62; emphasis added.) 

Lavelle teaches a frames buffer that contains two sets of banks; Lavelle does not 

disclose or suggest a buffer that comprises one or more banks from a first set of banks and a 

10 buffer that comprises one or more banks from a second set of banks. Lavelle also does not 

disclose or suggest allocatine a buffer that comprises one or more banks from a first set of banks 

and a buffer that comprises one or more banks from a second set of banks in response to a buffer 

request . 

Thus, MuUer et al,, Sindhu et al., and Lavelle et al., alone or in combination, do 
15 not disclose or suggest wherein said banks are divided into a first set of banks and a second set of 
banks, and further comprising the step of allocating a buffer that comprises one or more banks 
from said first set and a buffer that comprises one or more banks from said second set in 
response to a buffer request, as required by claims 6 and 22. 

20 Conclusion 

The rejections of the cited claims imder section 103 in view of MuUer et al., 
Sindhu et al., Benson et al., Kamaraj et al., Beshai, Lavelle et al., and Manning et al., alone or in 
any combination, are therefore believed to be improper and should be withdrawn. The remaining 
rejected dependent claims are believed allowable for at least the reasons identified above with 

25 respect to the independent claims. 
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The attention of the Examiner and the Appeal Board to this matter is appreciated. 



Respectfully, 



Date: June 23, 2011 Kevin M. Mason 

Attorney for Applicant(s) 
Reg. No. 36,597 
Ryan, Mason «& Lewis, LLP 
1300 Post Road, Suite 205 
Fairfield, CT 06824 
(203) 255-6560 
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CLAIMS APPENDIX 

1. A method for storing a packet in a shared memory in a packet switch, said 
method comprising the step of: 

5 Storing in said shared memory, wherein said shared memory comprises two or 

more buffers and two or more banks, at least a portion of a packet in contiguous banks of a first 
buffer of said two or more buffers, wherein each of said banks comprises portions, wherein each 
of said two or more buffers comprises a portion from each of said plurality of banks, and wherein 
each of said buffers identifies an address of a location in each of said banks. 

10 

2. The method of claim 1, wherein said packet comprises a plurality of portions, and 
further comprising the step of storing an additional portion of said packet in contiguous banks of 
a second buffer if one of said portions is stored in a last bank of said first buffer and said portion 
stored in said last bank of said first buffer is not a last portion of said packet. 

15 

3. The method of claim 1, wherein each of said two or more buffers comprises one 
or more groups and each of said groups comprises a plurality of banks. 

4. The method of claim 1, wherein at least a portion of each of two or more packets 
20 are stored in one of said buffers. 

5. The method of claim 1, further comprising the step of cyclically accessing one or 
more data ports, each of said data ports corresponding to one or more of said plurality of banks. 

25 6. The method of claim 1, wherein said banks are divided into a first set of banks 

and a second set of banks, and further comprising the step of allocating a buffer that comprises 
one or more banks from said first set and a buffer that comprises one or more banks from said 
second set in response to a buffer request. 

30 7. The method of claim 1, wherein said shared memory exchanges packets between 

ports in said packet switch. 
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8. The method of claim 1, wherein sequential data units of said packet are stored in 
contiguous banks of at least one of said two or more buffers. 

9. A method for managing a shared memory in a packet switch, said shared memory 
5 comprising one or more buffers, said method comprising the step of: 

maintaining a buffer usage count for at least one of said buffers, wherein said 
buffer usage count provides an indication of a sum over all packets in said at least one of said 
buffers of a number of output ports toward which each of said packets is destined, wherein said 
at least one of said buffers contains two or more packets and wherein at least one of said two or 
10 more packets is destined for more than one output port; and 

adding said at least one of said buffers to a free buffer list if a release of said at 
least one of said buffers does not occur within a predefined period of time. 

10. The method of claim 9, further comprising the step of incrementing said buffer 
15 usage count by one to indicate that a packet destined for one output port is stored in said buffer. 

11. The method of claim 9, fiirther comprising the step of decrementing said buffer 
usage count by one when a data unit is read from said buffer and said data unit is the last data 
unit of a packet or the last data unit of said buffer. 

20 

12. The method of claim 9, wherein said buffer usage count indicates a number of 
destination ports for a packet to perform a multicasting operation. 

13. The method of claim 9, further comprising the step of determining whether a 
25 buffer is free based on said buffer usage coimt. 

14. (Cancelled) 

15. (Cancelled) 

30 

16. (Cancelled) 
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17. (Cancelled) 

18. A shared memory for storing a packet, comprising: 

two or more buffers and two or more banks, wherein each of said banks 
5 comprises portions, wherein each of said two or more buffers comprises a portion from each of 
said plurality of banks, wherein each of said buffers identifies an address of a location in each of 
said banks, and wherein at least a portion of said packet is stored in contiguous banks of a first 
buffer of said two or more buffers. 

10 19. The shared memory of claim 18, wherein said packet comprises a plurality of 

portions, and wherein an additional portion of said packet is stored in contiguous banks of a 
second buffer if one of said portions is stored in a last bank of said first buffer and said portion 
stored in said last bank of said first buffer is not a last portion of said packet. 

15 20. The shared memory of claim 18, wherein each of said two or more buffers 

comprises one or more groups and each of said groups comprises a plurality of banks. 

21. The shared memory of claun 18, wherein at least a portion of each of two or 
more packets are stored in one of said buffers, 

20 

22. The shared memory of claim 18, wherein said banks are divided into a first set of 
banks and a second set of banks, and further comprising the step of allocating a buffer tiiat 
comprises one or more banks from said first set and a buffer that comprises one or more banks 
from said second set in response to a buffer request. 

25 

23. The shared memory of claim 18, wherein said shared memory exchanges packets 
between ports in a packet switch. 

24. The shared memory of claim 18, further comprising a counter for monitoring a 
30 buffer usage count that provides an indication of the sum over all packets in said at least one of 

said buffers of the number of output ports toward which each of said packets is destined. 
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EVIDENCE APPENDIX 
There is no evidence submitted pursuant to § 1.130, 1.131, or 1.132 or entered by 
the Examiner and relied upon by appellant. 



-10- 



Terablaze 4 
Confirmation No. 6402 

RELATED PROCEEDINGS APPENDIX 
There are no known decisions rendered by a court or the Board in any proceeding 
identified pursuant to paragraph (c)(l)(ii) of 37 CFR 41.37. 
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